﻿@page
@using Microsoft.AspNetCore.Authorization
@using Microsoft.AspNetCore.Http.Extensions
@using Microsoft.Extensions.Options
@using Volo.Abp.Users
@using Volo.Blogging
@using Volo.Blogging.Pages.Blog.Posts
@using Volo.Blogging.Areas.Blog.Helpers.TagHelpers
@using Volo.Abp.AspNetCore.Mvc.UI.Packages.Prismjs
@using Volo.Blogging.SocialMedia
@inject IAuthorizationService Authorization
@inject IOptionsSnapshot<BloggingTwitterOptions> twitterOptions
@using Microsoft.AspNetCore.Mvc.Localization
@using Volo.Blogging.Localization
@using Volo.Blogging.Pages.Blog
@inject IHtmlLocalizer<BloggingResource> L
@inject BloggingPageHelper BloggingPageHelper
@inject ICurrentUser CurrentUser
@model DetailModel
@{
    ViewBag.Title = Model.Post.Title;
    ViewBag.Description = Model.Post.Description;

    ViewBag.TwitterCard = "summary_large_image";
    ViewBag.TwitterSite = string.IsNullOrWhiteSpace(twitterOptions.Value.Site) ? "" : twitterOptions.Value.Site;
    ViewBag.TwitterTitle = Model.Post.Title;
    ViewBag.TwitterDescription = Model.Post.Description;
    ViewBag.TwitterImage = $"{Request.Scheme}://{Request.Host}{Request.PathBase}{Model.Post.CoverImage}";

    ViewBag.LinkedInUrl = Request.GetEncodedUrl();
    ViewBag.LinkedInTitle = Model.Post.Title;
    ViewBag.LinkedInDescription = Model.Post.Description;
    ViewBag.LinkedInImage = $"{Request.Scheme}://{Request.Host}{Request.PathBase}{Model.Post.CoverImage}";

    var hasCommentingPermission = CurrentUser.IsAuthenticated; //TODO: Apply real policy!
}
@section scripts {
    <abp-script-bundle name="@typeof(DetailModel).FullName">
        <abp-script type="@typeof(PrismjsScriptBundleContributor)" />
        <abp-script src="/Pages/Blogs/Posts/detail.js" />
    </abp-script-bundle>
}
@section styles {
    <abp-style-bundle name="@typeof(DetailModel).FullName">
        <abp-script type="@typeof(PrismjsStyleBundleContributor)" />
        <abp-style src="/Pages/Blogs/Shared/Styles/blog.css" />
    </abp-style-bundle>
}

<div class="vs-blog vs-blog-detail">
    <abp-input asp-for="FocusCommentId" class="m-0" />
    <div class="container">
        <div class="row">
            <div class="col-12 col-md-8 col-lg-7 mx-auto">
                <section class="hero-section">
                    <div class="hero-articles">
                        <div class="hero-content">
                            <h1 class="mb-3">
                                <a asp-page="./Detail" asp-route-postUrl="@Model.Post.Url" asp-route-blogShortName="@Model.BlogShortName" id="PostTitle">@Model.Post.Title</a>
                            </h1>

                            <div class="article-owner">
                                <div class="article-infos">
                                    <div class="user-card mt-3 mb-4">
                                        <div class="row">
                                            <div class="col-auto pr-1">
                                                @if (Model.Post.Writer != null)
                                                {
                                                    <img gravatar-email="@Model.Post.Writer.Email" default-image="Identicon" class="article-avatar" />
                                                }
                                            </div>
                                            <div class="col pl-1">
                                                @if (Model.Post.Writer != null)
                                                {
                                                    <h5 class="mt-2 mb-1">@(Model.Post.Writer.UserName) <span>@BloggingPageHelper.ConvertDatetimeToTimeAgo(Model.Post.CreationTime)</span></h5>

                                                }

                                                <i class="fa fa-eye"></i> @L["WiewsWithCount", @Model.Post.ReadCount]
                                                <span class="vs-seperator">|</span>
                                                <i class="fa fa-comment"></i> @L["CommentWithCount", @Model.CommentCount]


                                                @if (await Authorization.IsGrantedAsync(BloggingPermissions.Posts.Update))
                                                {
                                                    <span class="seperator">|</span>
                                                    <a asp-page="./Edit" asp-route-postId="@Model.Post.Id" asp-route-blogShortName="@Model.BlogShortName">
                                                        <i class="fa fa-pencil"></i> @L["Edit"]
                                                    </a>
                                                }
                                                @if (await Authorization.IsGrantedAsync(BloggingPermissions.Posts.Delete) || (CurrentUser.Id.HasValue && CurrentUser.Id == Model.Post.CreatorId))
                                                {
                                                    <span class="seperator">|</span>
                                                    <a href="#" id="DeletePostLink" data-postid="@Model.Post.Id" data-blogShortName="@Model.BlogShortName">
                                                        <i class="fa fa-trash"></i> @L["Delete"]
                                                    </a>
                                                }
                                            </div>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <div class="img-container mb-3">
                            <img src="@Model.Post.CoverImage" />
                        </div>
                    </div>
                </section>
            </div>
        </div>

        <div class="row">
            <div class="col-12 col-md-8 col-lg-7 mx-auto">
                <section class="post-content">
                    <p>
                        @Html.Raw(BloggingPageHelper.RenderMarkdownToHtml(Model.Post.Content))
                    </p>
                </section>
            </div>
        </div>

        <div class="row">
            <div class="col-12 col-md-8 col-lg-7 mx-auto">
                <hr />
                <div class="mb-2 mt-1">
                    @(L["ShareOn"].Value + " :")
                    <a href="#" target="_blank" class="mr-2" id="TwitterShareLink" title="Twitter">
                        Twitter <i class="fa fa-twitter"></i>
                    </a>
                    <a href="#" target="_blank" class="mr-2" id="LinkedinShareLink" title="LinkedIn">
                        Linkedin <i class="fa fa-linkedin"></i>
                    </a>
                    <a href="#" target="_blank" class="mr-2" id="EmailShareLink" title="E-mail">
                        E-mail <i class="fa fa-envelope-square"></i>
                    </a>
                </div>
                @if (Model.Post.Tags.Count > 0)
                {
                    <div class="tags">
                        <h5>@L["TagsInThisArticle"]</h5>
                        @foreach (var tag in Model.Post.Tags)
                        {
                            <a asp-page="/Blogs/Posts/Index" asp-route-blogShortName="@Model.BlogShortName" asp-route-tagName="@tag.Name" class="tag">@tag.Name</a>
                        }
                    </div>
                }

                @if (Model.CommentsWithReplies.Count > 0)
                {
                    <abp-row v-align="Start">
                        <abp-column size-sm="_12">
                            <p class="float-left"><i class="fa fa-comment"></i> @L["CommentWithCount", @Model.CommentCount]</p>
                            @if (hasCommentingPermission)
                            {
                                <a abp-button="Primary" class="btn-rounded float-right active" href="#LeaveComment">@L["LeaveComment"]</a>
                            }
                            else
                            {
                                <a abp-button="Primary" class="btn-rounded float-right active" href="/Account/Login?returnUrl=@System.Web.HttpUtility.UrlEncode(@Request.Path)">@L["LeaveComment"]</a>
                            }
                        </abp-column>
                    </abp-row>

                    <div class="comment-area">
                        @foreach (var commentWithRepliesDto in Model.CommentsWithReplies)
                        {
                            <div class="media">
                                <img gravatar-email="@commentWithRepliesDto.Comment.Writer.Email" default-image="Identicon" class="d-flex mr-3 rounded-circle comment-avatar" />
                                <div class="media-body">
                                    <h5 class="comment-owner">
                                        @(commentWithRepliesDto.Comment.Writer == null ? "" : commentWithRepliesDto.Comment.Writer.UserName)
                                        <span>@BloggingPageHelper.ConvertDatetimeToTimeAgo(commentWithRepliesDto.Comment.CreationTime)</span>
                                    </h5>
                                    <p id="@commentWithRepliesDto.Comment.Id">
                                        @commentWithRepliesDto.Comment.Text
                                    </p>
                                    <div class="comment-buttons">

                                        @if (hasCommentingPermission)
                                        {
                                            <a href="#" class="tag replyLink" data-relpyid="@commentWithRepliesDto.Comment.Id">
                                                <i class="fa fa-reply" aria-hidden="true"></i> @L["Reply"]
                                            </a>
                                        }

                                        @if (await Authorization.IsGrantedAsync(BloggingPermissions.Comments.Delete) || (CurrentUser.Id == commentWithRepliesDto.Comment.CreatorId))
                                        {
                                            <span class="seperator">|</span>
                                            <a href="#" class="tag deleteLink" data-deleteid="@commentWithRepliesDto.Comment.Id">
                                                <i class="fa fa-trash" aria-hidden="true"></i> @L["Delete"]
                                            </a>
                                        }

                                        @if (await Authorization.IsGrantedAsync(BloggingPermissions.Comments.Update) || (CurrentUser.Id == commentWithRepliesDto.Comment.CreatorId))
                                        {
                                            <span class="seperator">|</span>
                                            <a href="#" class="tag updateLink" data-updateid="@commentWithRepliesDto.Comment.Id">
                                                <i class="fa fa-pencil" aria-hidden="true"></i> @L["Edit"]
                                            </a>
                                        }
                                    </div>

                                    @if (hasCommentingPermission)
                                    {
                                        <div class="comment-form mt-4 replyForm">
                                            <div class="clearfix p-4">
                                                <h3 class="mt-0">
                                                    @L["ReplyTo", commentWithRepliesDto.Comment.Writer == null ? "" : commentWithRepliesDto.Comment.Writer.UserName]

                                                </h3>
                                                <div>
                                                    <form method="post">
                                                        <input name="postId" value="@Model.Post.Id" hidden />
                                                        <input name="repliedCommentId" value="@commentWithRepliesDto.Comment.Id" hidden />

                                                        <div class="form-group">
                                                            <textarea class="form-control" name="text" id="textBoxId" rows="4"></textarea>
                                                        </div>
                                                        <abp-button button-type="Primary" class="btn-rounded float-right" type="submit" text="@L["Comment"].Value" />
                                                        <abp-button button-type="Danger" class="btn-rounded float-right replyCancelButton" text="@L["Cancel"].Value" />
                                                    </form>
                                                </div>
                                            </div>
                                        </div>
                                    }
                                    @if (await Authorization.IsGrantedAsync(BloggingPermissions.Comments.Update) || (CurrentUser.Id == commentWithRepliesDto.Comment.CreatorId))
                                    {
                                        <div class="comment-form mt-4 editForm">
                                            <div class="clearfix p-4">
                                                <div>
                                                    <form class="editFormClass">
                                                        <input name="commentId" value="@commentWithRepliesDto.Comment.Id" hidden />
                                                        <div class="form-group">
                                                            <textarea class="form-control" name="text" id="textBoxId" rows="4">@commentWithRepliesDto.Comment.Text</textarea>
                                                        </div>
                                                        <abp-button button-type="Primary" class="btn-rounded float-right" type="submit" text="@L["Submit"].Value" />
                                                        <abp-button button-type="Danger" class="btn-rounded float-right editCancelButton" text="@L["Cancel"].Value" />
                                                    </form>
                                                </div>
                                            </div>
                                        </div>
                                    }

                                    @foreach (var reply in commentWithRepliesDto.Replies)
                                    {
                                        <div class="media">
                                            <img gravatar-email="@reply.Writer.Email" default-image="Identicon" class="d-flex mr-3 rounded-circle comment-avatar" />
                                            <div class="media-body">
                                                <h5 class="comment-owner">
                                                    @(reply.Writer == null ? "" : reply.Writer.UserName)
                                                    <span>@BloggingPageHelper.ConvertDatetimeToTimeAgo(reply.CreationTime)</span>
                                                </h5>
                                                <p id="@reply.Id">
                                                    @reply.Text
                                                </p>
                                                <div class="comment-buttons">

                                                    @if (hasCommentingPermission)
                                                    {
                                                        <a href="#" class="tag replyLink" data-relpyid="@commentWithRepliesDto.Comment.Id">
                                                            <i class="fa fa-reply" aria-hidden="true"></i> @L["Reply"]
                                                        </a>
                                                    }
                                                    @if (await Authorization.IsGrantedAsync(BloggingPermissions.Comments.Delete) || (CurrentUser.Id == commentWithRepliesDto.Comment.CreatorId))
                                                    {
                                                        <span class="seperator">|</span>
                                                        <a href="#" class="tag deleteLink" data-deleteid="@reply.Id">
                                                            <i class="fa fa-trash" aria-hidden="true"></i> @L["Delete"]
                                                        </a>
                                                    }

                                                    @if (await Authorization.IsGrantedAsync(BloggingPermissions.Comments.Update) || (CurrentUser.Id == commentWithRepliesDto.Comment.CreatorId))
                                                    {
                                                        <span class="seperator">|</span>
                                                        <a href="#" class="tag updateLink" data-updateid="@reply.Id">
                                                            <i class="fa fa-pencil" aria-hidden="true"></i> @L["Edit"]
                                                        </a>
                                                    }
                                                </div>

                                                @if (hasCommentingPermission)
                                                {
                                                    <div class="comment-form mt-4 replyForm">
                                                        <div class="clearfix bg-light py-4">
                                                            <h3 class="mt-0">
                                                                @L["ReplyTo", commentWithRepliesDto.Comment.Writer == null ? "" : commentWithRepliesDto.Comment.Writer.UserName]
                                                            </h3>
                                                            <div>
                                                                <form method="post">
                                                                    <input name="postId" value="@Model.Post.Id" hidden />
                                                                    <input name="repliedCommentId" value="@commentWithRepliesDto.Comment.Id" hidden />
                                                                    <div class="form-group">
                                                                        <textarea class="form-control" name="text" id="textBoxId" rows="4"></textarea>
                                                                    </div>
                                                                    <abp-button button-type="Primary" class="btn-rounded float-right" type="submit" text="@L["Submit"].Value" />
                                                                    <abp-button button-type="Danger" class="btn-rounded float-right replyCancelButton" text="@L["Cancel"].Value" />
                                                                </form>
                                                            </div>
                                                        </div>
                                                    </div>
                                                }
                                                @if (await Authorization.IsGrantedAsync(BloggingPermissions.Comments.Update) || (CurrentUser.Id == commentWithRepliesDto.Comment.CreatorId))
                                                {
                                                    <div class="comment-form mt-4 editForm">
                                                        <div class="clearfix bg-light py-4">
                                                            <div>
                                                                <form class="editFormClass">
                                                                    <input name="commentId" value="@reply.Id" hidden />
                                                                    <div class="form-group">
                                                                        <textarea class="form-control" name="text" id="textBoxId" rows="4">@reply.Text</textarea>
                                                                    </div>
                                                                    <abp-button button-type="Primary" class="btn-rounded float-right" type="submit" text="@L["Submit"].Value" />
                                                                    <abp-button button-type="Danger" class="btn-rounded float-right editCancelButton" text="@L["Cancel"].Value" />
                                                                </form>
                                                            </div>
                                                        </div>
                                                    </div>
                                                }
                                            </div>
                                        </div>
                                    }
                                </div>
                            </div>
                        }
                    </div>
                }

                @if (hasCommentingPermission)
                {
                    <div class="comment-form mt-4" id="LeaveComment">
                        <div class="vs-blog-title mb-0">
                            <h3>@L["LeaveComment"]</h3>
                        </div>
                        <div class="clearfix bg-light py-4">
                            <div>
                                <form method="post">
                                    <input name="postId" value="@Model.Post.Id" hidden />
                                    <input name="repliedCommentId" id="repliedCommentId" hidden />
                                    <div class="form-group">
                                        <textarea class="form-control" name="text" id="textBoxId" rows="4"></textarea>
                                    </div>
                                    <abp-button button-type="Primary" class="btn-rounded float-right" type="submit" text="@L["Submit"].Value" />
                                </form>
                            </div>
                        </div>
                    </div>
                }
                else
                {
                    <a abp-button="Primary" class="btn-rounded float-right active mt-3" href="/Account/Login?returnUrl=@System.Web.HttpUtility.UrlEncode(@Request.Path)">@L["LeaveComment"]</a>
                }
            </div>
        </div>
    </div>
</div>
<p id="BlogFullName" name="@Model.Blog.Name" hidden></p>
